Hibernate এর কাজের প্রক্রিয়া এবং মূল ধারণা

Java Technologies - স্প্রিং বুট ওআরএম (Spring Boot ORM) - Hibernate ORM এর পরিচিতি
181

Hibernate হলো জাভা-ভিত্তিক একটি Object Relational Mapping (ORM) ফ্রেমওয়ার্ক, যা ডেটাবেস অপারেশন সহজ করে। এটি JPA (Java Persistence API) এর একটি জনপ্রিয় ইমপ্লিমেন্টেশন এবং স্প্রিং বুটে ORM পরিচালনার জন্য বহুল ব্যবহৃত হয়।

Hibernate ডাটাবেসের সঙ্গে কাজ করার জন্য Object-Oriented পদ্ধতি ব্যবহার করে। এটি ডেটাবেসের টেবিল ও কলামগুলোকে জাভার ক্লাস ও ফিল্ডে ম্যাপ করে এবং SQL লেখার প্রয়োজনীয়তা হ্রাস করে।


Hibernate এর কাজের প্রক্রিয়া

Hibernate মূলত নিম্নলিখিত প্রক্রিয়াগুলোর মাধ্যমে কাজ করে:

১. Entity ক্লাস তৈরি

Hibernate একটি Entity ক্লাসের মাধ্যমে ডাটাবেসের টেবিলের কাঠামোকে রিপ্রেজেন্ট করে। Entity ক্লাসে @Entity, @Table, @Id, এবং অন্যান্য এনোটেশন ব্যবহার করে টেবিল ও কলাম ম্যাপিং করা হয়।

import jakarta.persistence.Entity;
import jakarta.persistence.Id;
import jakarta.persistence.GeneratedValue;
import jakarta.persistence.GenerationType;

@Entity
public class Employee {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;
    private String name;
    private String department;

    // Getters and Setters
}

২. SessionFactory তৈরি

Hibernate এর মাধ্যমে ডেটাবেসের সঙ্গে যোগাযোগ স্থাপন করার জন্য SessionFactory ব্যবহার করা হয়। এটি কনফিগারেশন তথ্য ব্যবহার করে একটি সেশন তৈরির দায়িত্ব পালন করে।

SessionFactory sessionFactory = new Configuration().configure().buildSessionFactory();

৩. Session পরিচালনা

Session হলো Hibernate এর মূল উপাদান, যা ডেটাবেস অপারেশন পরিচালনা করে। Session এর মাধ্যমে ডেটাবেসে CRUD (Create, Read, Update, Delete) অপারেশন সম্পন্ন করা হয়।

Session session = sessionFactory.openSession();
session.beginTransaction();

Employee employee = new Employee();
employee.setName("John Doe");
employee.setDepartment("IT");

session.save(employee);
session.getTransaction().commit();
session.close();

৪. SQL Generation

Hibernate Entity ক্লাসের ভিত্তিতে স্বয়ংক্রিয়ভাবে SQL তৈরি করে। উদাহরণস্বরূপ, উপরের কোডে Hibernate একটি INSERT কুয়েরি তৈরি করে:

INSERT INTO employee (name, department) VALUES ('John Doe', 'IT');

৫. Caching

Hibernate ডেটাবেস অপারেশন দ্রুত করার জন্য ক্যাশিং ব্যবহার করে। এটি মূলত দুই স্তরের ক্যাশিং পরিচালনা করে:

  • First-Level Cache: Session-ভিত্তিক।
  • Second-Level Cache: পুরো অ্যাপ্লিকেশন জুড়ে ব্যবহৃত।

Hibernate এর মূল ধারণা

১. ORM (Object Relational Mapping)

Hibernate এর মূল ভিত্তি হলো ORM। এটি অবজেক্ট এবং রিলেশনাল ডেটাবেসের মধ্যে একটি ম্যাপিং তৈরি করে। ডেটাবেস টেবিলের রো গুলোকে জাভার অবজেক্টে রূপান্তর করা হয় এবং অবজেক্টগুলোর পরিবর্তন ডাটাবেসে প্রতিফলিত হয়।

২. Persistence Context

Persistence Context হলো Hibernate এর মাধ্যমে অবজেক্ট ট্র্যাকিংয়ের একটি প্রক্রিয়া। এটি ডেটাবেস এবং জাভার অবজেক্টের মধ্যে সিনক্রোনাইজেশন নিশ্চিত করে।

৩. Lazy and Eager Loading

Hibernate ডেটা লোড করার জন্য দুটি পদ্ধতি অনুসরণ করে:

  • Lazy Loading: প্রয়োজনীয় হলে ডেটা লোড করে।
  • Eager Loading: শুরুতেই সমস্ত ডেটা লোড করে।

৪. Query Language (HQL)

Hibernate একটি নিজস্ব কুয়েরি ভাষা (Hibernate Query Language - HQL) ব্যবহার করে, যা অবজেক্ট-ভিত্তিক এবং SQL এর মতো দেখতে। উদাহরণ:

Query query = session.createQuery("FROM Employee WHERE department = :dept");
query.setParameter("dept", "IT");
List<Employee> employees = query.list();

৫. Transaction Management

Hibernate ট্রানজ্যাকশন পরিচালনার জন্য Transaction API ব্যবহার করে, যা ডেটাবেস অপারেশনগুলোর একক এক্সিকিউশন নিশ্চিত করে।


Hibernate এর সুবিধা

  • SQL লেখার প্রয়োজনীয়তা হ্রাস: Hibernate স্বয়ংক্রিয়ভাবে SQL তৈরি করে।
  • Database Independence: একাধিক ডেটাবেস সাপোর্ট করে।
  • Object-Oriented পদ্ধতি: ডেটাবেস পরিচালনার জন্য অবজেক্ট ব্যবহারের সুবিধা।
  • Caching সুবিধা: দ্রুত ডেটা প্রসেসিং নিশ্চিত করে।
  • Lazy এবং Eager Loading: ডেটা লোডিংয়ের নমনীয়তা।

সারাংশ

Hibernate স্প্রিং বুট এবং অন্যান্য জাভা-ভিত্তিক অ্যাপ্লিকেশনে ORM ইমপ্লিমেন্টেশনের জন্য একটি শক্তিশালী টুল। এটি ডেটাবেস অপারেশনগুলোকে সহজ, দ্রুত এবং আরও কার্যকর করে তোলে। এর স্বয়ংক্রিয় SQL জেনারেশন এবং ক্যাশিং সুবিধা উন্নত পারফরম্যান্স নিশ্চিত করে।


Content added By
Promotion
NEW SATT AI এখন আপনাকে সাহায্য করতে পারে।

Are you sure to start over?

Loading...